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System for Forming and Processing an MPEG Compatible 
Datastream Incorporating Internet Information 

5 

Field of the Invention 

This invention is related to the field of digital signal 

1 0 processing, and more particularly to a data format and to a system 

for decoding MPEG compatible data incorporating Internet 
information. 

Background of the Invention 

15 

Home entertainment systems which combine -Personal 
Computer and television functions (PC/TV systems), are 
increasingly becoming, generic, User interactive, multiple source 
and multiple destination communication devices. Such systems are 

2 0 required to communicate in different data formats between 

multiple locations for a variety of applications in response to User 
requests. For example, a PC/TV system may receive data from 
satellite or terrestrial sources comprising High Definition 
Television (HDTV) broadcasts, Multi-point Microwave Distribution 

2 5 System (MMDS) broadcasts and Digital Video Broadcasts (DVB). A 

PC/TV system may also receive and transmit data via telephone 
(e.g. the Internet) and coaxial lines (e.g. cable TV) and from both 
remote and local sources such as Digital Video Disk (DVD), CDROM, 
VHS and Digital VHS (DVHS™) type players, PCs, and many other 

3 0 types of sources. 

A number of problems arise in developing such a 
generic PC/TV entertainment system. Specifically, problems arise 
in supporting communication between multiple data sources and 
in processing data from the multiple sources. A problem is also 
3 5 presented by the need to devise a User interface for such a system 
that supports complex User interactive tasks whilst providing a 
simple command interface suitable for the general public. A 
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PC/TV system User interface, for example, should allow a User to 
view a selected program and permit User operation of functions 
such as Email, telephone, Internet access, .fax and video-phone 
functions. Such applications require communication between a 
5 PC/TV unit and a variety of both remote sources e.g. a satellite 
service provider, and local sources e.g. a DVD storage device. 
Further, a PC/TV needs to process and decode data in different 
data formats from different devices and display received data to 
the User. These problems are addressed by a system according to 
1 0 the present invention. 

Summary of the Invention 

The inventors have hereby recognized that a Program 
15 Guide type of User interface advantageously provides a simple, 
easy to use interface for User operation of functions such as Email, 
telephone, Internet access, fax, home control, and video-phone 
functions. The use of a Program Guide for such functions also 
advantageously provides a single User interface for User operation 
2 0 of multiple devices and associated functions. 

The inventors have further recognized that Internet 
information requested via a program guide or other type of User 
interface may be advantageously conveyed in a composite data 
format including MPEG compatible video data. They have further 

2 5 recognized that it is desirable for a video decoder system to be 

capable of decoding such a composite data format. 

A disclosed data format includes MPEG compatible 
video data and Internet image information suitable for conveying 
packetized video program data and associated web image 

3 0 information. The data format comprises MPEG system data that 

includes a first transport packet with a header containing a first 
data identifier (PID) for identifying the video program data in a 
payload of the first transport packet. The MPEG system data also 
includes a second transport packet containing a second data 
3 5 identifier (PID) for identifying Internet information contained in a 
payload of the second transport packet. The MPEG system data 
also includes ancillary, data supporting the identification and 
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decoding of the Internet information and containing the second 
data identifier. 

In a feature of the invention, a method for decoding 
data coded in the composite data format involves applying the 
5 ancillary data in identifying, decoding and assembling the Internet 
information. 

In another feature of the invention, a method for 
decoding data coded in the composite data format involves 
synchronizing the Internet information with the video program 
1 0 using the ancillary data. 

Brief Description of the Drawings 

In the drawing: 

1 5 Figure 1 shows a home entertainment decoder system, 

according to the invention, for communicating with a plurality of 
sources and for processing program guide information and 
program content data. 

2 0 Figure 2 shows an exemplary Program Guide display 

format according to the invention. 

Figure 3 shows a data format, according to the 
invention, for packetizing Internet data for transmission within an 

2 5 MPEG compatible datastream. 

Figure 4 shows a flowchart, according to the invention, 
for receiving program guide information including User selection 
options and processing the received information to form a 

3 0 program guide supporting User selectable communication 

functions. 

Figure 5 shows a flowchart, according to the invention, 
for a process to form a program guide in a video decoder from 
3 5 information received from a plurality of sources. 
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Figure 6 shows a flowchart, according to the invention, 
for a process to automatically acquire and collate program guide 
information from a plurality of sources and to form a program 
guide for display. 

5 

Figure 7 shows a black and white representation of an 
exemplary color Program Guide display format, according to the 
invention, showing menu options permitting a User to collate 
programs by source and color attribute. 

10 

Figure 8 shows a flowchart, according to the invention, 
for a process to acquire information requested by a video receiver 
User via a selection made from options on a displayed program 
guide. 

15 

Figure 9 shows a flowchart, according to the invention, 
for a process to decode input Internet information and 
compressed video data and to form a composite video output for 
display. 

20 

Detailed Description of the Drawings 

Figure 1 shows a home entertainment decoder system, 
according to the invention, for communicating with multiple 

2 5 sources to acquire program guide information and program 

content data. The decoder system forms a program guide for 
display from information acquired and collated automatically from 
multiple sources. A User may initiate Email, telephone, Internet 
access, fax and video-phone functions via selection of options from 

3 0 the displayed program guide. The decoder system adaptively 

decodes a datastream encoded to the MPEG standard incorporating 
compressed program content data and Internet data 
representative of, for example, Hypertext Mark-up Language 
(HTML). The decoded data is formatted either as a composite 
3 5 video image or as separate video images for display. 

The MPEG2 (Moving Pictures Expert Group) image 
encoding standard, hereinafter referred to as the "MPEG standard" 
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is comprised of a system encoding section (ISO/IEC 13818-1, 10th 
June 1994) and a video encoding section (ISO/IEC 13818-2, 20th 
January 1995), hereinafter referred to as . the "MPEG systems 
standard" and "MPEG video standard" respectively. 
5 Although the disclosed system is described in the 

context of a system for receiving an MPEG compatible signal, it is 
exemplary only. The principles of the invention may be applied to 
systems in which the types of transmission channels and 
communication protocols may vary, or to systems in which the 
1 0 coding type may vary. Such systems may include, for example, 
non-MPEG compatible systems, involving other types of encoded 
datastreams and other methods of conveying Program Guide 
information. Further, although the disclosed system is described as 
processing broadcast programs, this is exemplary only. The term 

1 5 'program 1 is used to represent any form of data such as telephone 

messages, computer programs, Internet data or- other 
communications, for example. 

In overview, in the video receiver system of Figure 1, 
a carrier modulated with video data is received from a broadcast 

2 0 satellite by antenna 10 and processed by unit 15. The resultant 

digital output signal is demodulated by demodulator 20 and 
decoded and error corrected by decoder 30. In this exemplary 
embodiment, the demodulated and decoded output from unit 30 is 
in the form of an MPEG compatible transport stream containing 

2 5 MPEG compressed video data and Internet data encoded in HTML. 

Video data encoded to the MPEG standard is in the form of a 
packetized datastream which typically includes the data content of 
many program channels (e.g, content corresponding to cable 
television channels 1-125). 

3 0 The MPEG compatible transport stream is provided to 

processor 25 which is responsive to commands from remote 
control unit 125. Processor 25 communicates with other data 
sources including storage device 90 and either Internet data 
server 83 or Internet connection service 87 (e.g. America On- 
3 5 line™). Program guide information is acquired and collated 
automatically from the input transport stream and storage device 
90 and either server 83 or connection service 87. The acquired 
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information is merged by processor 25 to form a program guide 
for display incorporating selection options allowing a User to 
initiate Email, telephone, Internet access, fax and video-phone 
functions among others, for example. The program guide for 
5 display is also formed to include non-displayed information from 
multiple sources for identifying and assembling individual data 
packets that constitute the programs that are selected for User 
viewing or listening. This information is used in recovering the 
content of selected programs from multiple sources. 
I o Processor 25 adaptively decompresses the input 

compressed video data and decodes the HTML Internet data to 
provide a formatted composite video image for display on unit 75. 
Processor 25 also provides encoded data outputs for storage oh 
storage medium 105 via storage device 90, and provides encoded 

1 5 data to other devices (not shown to simplify drawing) via modem 

80 and telephone lines. 

A video receiver user initiates functions including 
Email, telephone, Internet access, fax and video-phone functions 
and viewing and storage of selected programs via selection of 

2 0 options from the displayed program guide. A User selects a 

displayed option with a cursor using remote control unit 125. 
Commands from remote control 125 are passed via interface 120 
to controller 115 within processor 25. Unit 115 controls the 
operation of the elements of processor 25 and responds to remote 

2 5 control unit 125 commands using a bi-directional data and control 

signal bus C. Controller 115 controls the functions of individual 
elements within processor 25 by setting control register values 
within these elements with control bus C. Processor 25 also 
supports the storage and retrieval of data from storage medium 

3 0 105 via storage device 90. Storage device 90 is a DVD type device 

and medium 105 comprises a multi-disk stack unit containing a 
plurality of disks in this exemplary embodiment. 

Considering Figure 1 in detail, a carrier modulated 
with video data received by antenna 10, is converted to digital 
3 5 form and processed by- input processor 15. Processor 15 includes 
radio frequency (RF) tuner and intermediate frequency (IF) mixer 
and amplification stages for down-converting the input video 
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signal to a lower frequency band. Processor 15 also includes an 
analog to digital converter for digitizing the down-converted 
signal to produce a signal suitable for further processing. The 
resultant digital output signal is demodulated by demodulator 20 
5 and decoded and error-corrected by decoder 30. The output from 
decoder 30 is further processed by unit 45 of processor 25. 

The data provided to unit 45 is in the form of an MPEG 
compliant packetized transport datastream as defined in MPEG 
systems standard section 2.4 and includes program guide 

1 0 information and the data content of one or more program 
channels. Processor 25 acquires and collates program guide 
information automatically from the input transport stream and 
storage device 90 and either Internet data server 83 or Internet 
connection service 87 (e.g. America On-line™). The individual 

1 5 packets that comprise either particular program channel content, 
or Program Guide information, are identified by their Packet 
Identifiers (PIDs) contained within header information. 

In response to control signal C, unit 45 selects either 
the transport stream from unit 30, or in a playback mode, a 

2 0 datastream retrieved from storage device 90 via store interface 
95. In normal, non-playback operation, individual packets that 
comprise program guide information are identified by unit 45 in 
the transport stream from unit 30 and assembled using PIDs that 
are predetermined and stored in internal memory of controller 

2 5 115. Unit 45 matches the PIDs of incoming packets in the 

transport datastream from decoder 30 with PID values pre-loaded 
in control registers within unit 45 by controller 115. Therefore, 
satellite broadcast program guide (SPG) information packets in the 
transport stream are identified by unit 45 without additional PID 

3 0 information. Controller 115 acquires a full SPG by accessing and 

assembling the SPG packets that are identified and captured by 
unit 45. 

The PID information that enables controller 115, in 
conjunction with unit 45, to identify data packets that comprise 
3 5 individual programs is termed a program or channel map. The 
program map associates PIDs with individual packetized 
datastreams that constitute a program and is part of the SPG. The 
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SPG may also contain additional information, e.g. packet assembly 
information, supporting the recovery of program guide data from 
the input transport stream. 

Controller 115 also configures unit 45 using Control 
5 signal C to select the data packets comprising the DVD program 
guide (DPG) information derived from DVD storage device 90 via 
interface 95. Unit 45 matches the PIDs of incoming packets in the 
packet datastream from interface 95 with PID values pre-loaded 
in control registers within unit 45 by controller 115, Controller 

10 115 acquires a full DPG by accessing and assembling the DPG 
packets that are identified and captured by unit 45. 

A similar process is followed in acquiring Internet 
program guide (IPG) information from Internet server 83 or from 
Internet connection service 87 by telephone line communication 

1 5 via modem 80. In acquiring the IPG, data identifiers analogous to 
or the same as the PIDs used in acquiring the SPG or DPG are 
matched with identifiers pre-loaded by controller 115. The 
matching function may be performed either within unit 80 or by 
controller 115. The process for acquiring program guide 

2 0 information is explained in greater detail in the description of 
Figures 4-6. 

The SPG, DPG and IPG information acquired by 
controller 115 is merged by processor 25 to form a program guide 
for display incorporating selection options allowing a User to 

2 5 initiate Email, telephone, Internet access, fax and video-phone 

functions. In merging the data, the acquired SPG, DPG and IPG 
information is collated into two levels of hierarchy termed theme 
and topic and redundant program guide information is eliminated. 
A theme, for example, may include categories such as movies, 

3 0 sports, weather, arts, documentaries, news, etc. A topic is a 

category within a theme, for example, a movie theme category 
may have topics including, comedy, thriller, horror, science fiction, 
romance, adult entertainment, etc. Different or additional levels of 
hierarchy may be used in collating the acquired SPG, DPG and IPG 
3 5 information involving criteria such as viewer age suitability, the 
period setting e.g. contemporary or historical, reviewer ratings etc. 
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A number of problems occur in collating the SPG, DPG 
and IPG information. The SPG, DPG and IPG information, being 
from different sources, may categorize programs by different 
themes and topics and may use a different sorting hierarchy. 
5 Further, the SPG, DPG and IPG data may use conflicting, redundant 
or incompatible PIDs or other data identifiers for identifying 
individual data elements that comprise particular program 
channel or guide content. Controller 115 creates a master set of 
themes and topics mapping the SPG, DPG and IPG information to a 

1 0 corresponding category in the master set. For example, the master 

set may contain an encompassing topic-theme of Movies-comedy' 
to which is mapped both, a) the DPG topic-theme of "movie- 
parodies', and b) the IPG Internet topic-theme of 'movie-synopsis 
index' (an index of web pages). In collating the guide information, 
15 controller 115 determines the topic and theme categories of the 
data in the SPG, DPG and IPG from pre-determined theme-topic 
codes. The SPG, DPG and IPG theme arid topic codes together with 
equivalence mapping information for converting codes of one 
service provider, to those of another, are acquired from the SPG or 

2 0 User defined data input to processor 25 or are pre-stored in 

internal memory within controller 115. Controller 115 assembles 
the collated SPG, DPG and IPG packets according to the categories 
defined by the master set of themes and topics. The assembled 
collated SPG, DPG and IPG data is stored by controller 115 in 

2 5 internal memory for use in forming a composite program guide for 

display. 

Controller 115 also forms MPEG compatible non- 
displayed information, associated with the displayed composite 
program guide. The non-displayed information includes composite 

3 0 program map, conditional access and network information. This 

non-displayed information is required to support identification, 
assembly and decoding of the packets comprising the composite 
program guide and the associated program content. The 
conditional access information governs access to programs based 
3 5 upon User entitlement. The network information defines physical 
network parameters such as satellite transmission channel 
frequencies and transponder channels, for example. 
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Controller 115 forms composite program map 
information for the composite program guide that maps the SPG, 
DPG and IPG themes and topics to the master set of themes and 
topics. The composite program map also associates data identifiers 
5 (e.g. PID values) with individual packetized datastreams that 
constitute programs listed in the composite program guide. The 
composite program map information may also include a dedicated 
indicator to denote that a particular program has associated 
Internet web page information available. In forming composite 

10 program map information, controller 115 examines the SPG, DPG 
and IPG information for data identifier omissions, redundancies 
and conflicts. Controller 115 re-numbers existing data identifiers 
and creates new data identifiers as required to produce MPEG 
compatible program map information for both the collated 

1 5 program guide information and the associated program content. 

Controller 115 also forms MPEG compatible conditional 
access information and network information from corresponding 
information received in the SPG, DPG and IPG data. The conditional 
access information includes data such as encryption codes that 

2 0 govern access to programs that are dependent upon user 
entitlement. The network information defines physical network 
parameters such as satellite transmission channel frequencies, 
transponder channels, and Internet access parameters associated 
with the composite program guide for display. The composite 

2 5 program map, conditional access and network information 

supports assembly, decoding and display of the program content 
available from the satellite, storage and Internet server sources as 
well as the composite program guide. 

Controller 115 also includes additional linking data in 

3 0 the non-displayed composite program map, conditional access and 

network information. The additional linking data supports the 
User selectable functions such as Email, telephone, Internet access, 
fax, video-phone, channel tuning, program recording and home 
control functions. Home control functions may support User 
3 5 control of lighting air conditioning, heating and burglar alarm 
operation, for example. The additional linking data associates 
access data, both with data identifiers (e.g. PIDs) of requested 
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data, and with User selectable menu options in the displayed 
composite program guide. The access data includes identification 
codes, communication protocol codes, conditional access codes, 
Internet access codes e.g. URL codes for web page and Email access 
5 as well as telephone and fax numbers. The access data enables 
processor 25 to communicate with external devices. 

In order to generate the composite program guide for 
display, controller 115 retrieves the assembled and collated SPG, 
DPG and IPG packet data previously stored in internal memory. 

10 Controller 115 both converts the retrieved data to pixel data and 
formats the converted data for storage in a pixel representative 
memory map contained in display processor 70. In addition, 
controller 115 creates User selectable menu options (for User 
selection of Email, fax etc.) in pixel data form for incorporation in 

15 the unit 70 pixel memory map. Controller 115 stores the 
formatted SPG, DPG and IPG pixel data together with the 
generated option pixel data in the unit 70 pixel map to form the 
composite program guide for display. 

The composite program guide, combining the SPG, DPG 

2 0 and IPG data and User selectable options, is formatted to be 
compatible with the linking data in the non-displayed program 
guide information. For example, a User selectable option in the 
displayed guide (e.g. for a telephone function) is associated, both 
with access data for the function (e.g. a telephone number), and 

2 5 with data identifiers (e.g. PIDs for data packets of transmitted and 

received telephone messages). 

Display processor 70 converts the stored and 
formatted program guide data into conventional luminance and 
chrominance components. The luminance and chrominance 

3 0 components, together with timing data provided by controller 115, 

are processed by processor 70 in a conventional manner to form 
an NTSC signal for display on NTSC compatible image reproduction 
device 75 e.g. a television or video monitor. Processor 70 may, in 
another embodiment, provide RGB output data for display by an 
3 5 RGB compatible reproduction device or a high definition television. 

Controller 115, in conjunction with processor 55, forms 
an MPEG compatible datastream of compressed video and audio 
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data containing the composite program guide and program 
content. Processor 55 separates system information including 
timing, error and synchronization information from the 
datastream from unit 45 and diverts it for use by controller 115. 
5 Controller 115 applies the system information in controlling 
processor 55 to provide re-synchronized, collated program and 
composite program guide data together with synchronization and 
error indication information for use in subsequent program 
content data decompression by decoder 65. The composite 

1 0 program guide data provided by processor 55 combines the SPG, 
DPG and IPG data and User selectable options in a manner 
compatible with the program map linking information as 
previously described. The program content data provided by 
processor 55 is decompressed by MPEG decoder 65 to provide 

1 5 video pixel data and audio output data to processor 70. Display 
processor 70 processes the video pixel data and audio output data 
to be suitable for reproduction ' by unit 75 as previously described. 

Figure 2 shows an exemplary displayed composite 
program guide. Menu features 833-850 show program services 

2 0 and functions. Menu features 833 and 835 show program channels 
which may be invoked and displayed upon highlighting of the 
corresponding menu feature using a User selection control such as 
a remote control directed cursor. If a User highlights feature 833 
with the cursor, i.e. selects menu option 833, for example, 

2 5 processor 25 tunes to television channel 107 (A&E™) and displays 

it on unit 75 using the composite non-displayed program guide 
information to determine the function activated and associated 
tuning information (channel frequencies etc.). Similarly, if a User 
highlights feature 837, processor 25 tunes to receive radio channel 

3 0 FM 13 for audio output on unit 75. Upon highlighting features 

840-850, corresponding to Email, telephone, fax and DVD 
record/playback functions respectively, additional function 
specific menus become displayed providing further User selection 
options. Such function specific menus may provide a User with the 
3 5 ability to edit, store and delete access information including, for 
example, telephone numbers, Email addresses, Internet addresses, 
credit card numbers and additional conditional access data. 
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If a User highlights menu features 860-870 specific 
function tasks are initiated. Upon a User highlighting feature 860, 
for example, a further menu is displayed prompting the User to 
enter an Email message to be sent to John Smith at his home via 
5 an Internet Email address retrieved from the composite non- 
displayed program guide information. Similarly, in response to a 
User highlighting feature 865, for example, controller 115 (Figure 
1) retrieves Jean's home telephone number from internal memory 
using the composite non-displayed program guide information. 

1 0 Further, controller 115 establishes telephone communication, via 
modem 80, with Jean at her home by dialing Jean's home 
telephone number. Also, upon a User highlighting feature 870, for 
example, the movie 'Star Wars™' is re-played from DVD unit 90 
(Figure 1). The communication between processor 25 and DVD 

1 5 unit 90 is established with access data retrieved from memory 
within controller 115 using the composite non-displayed program 
guide information. 

In addition, the program guide may include one or 
more icons, such as icon 873 (Figure 2) depicting a home, for 

20 example, to indicate whether Internet information such as a 'home 
page' is available for a particular program. Further, icon 873, in 
Figure 2 may change color e.g. from white to green to indicate 
Internet information is available for a particular program. 
Alternatively, icon 873 may be a pop-up icon which appears as an 

2 5 indication that Internet information is available for a particular 

program. The displayed program guide may be formed to enable a 
User to request Internet information on a particular program by 
highlighting the program followed by highlighting the pop-up icon, 
for example. Home page icons that are present when Internet 

3 0 information is available may also located within or adjacent to 

program icons, e.g. icon 859. Further, the home page icon may 
change color upon User selection of the information by 
highlighting the home page icon. 

Although Internet information may be retrieved upon 
3 5 highlighting a web page icon such as icon 857, in Figure 2, this is 
exemplary only. Retrieval of Internet information may also be 
initiated in a variety of other ways. A user may retrieve available 
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Internet information relating to a program, by highlighting a 
program icon such as 'Seinfeld™ 1 using icon 859 followed by 
highlighting Internet icon 810, for example. 

Upon User selection of a composite program guide 
5 function, controller 115 (Figure 1) determines and applies the 
access data associated with both request and response operations 
involved in the selected function. Controller 115 determines the 
access data required for the request and response operations from 
the previously formed non-displayed composite program map, 
1 0 conditional access and network information. 

Processor 25 acquires information, such as web page 
data, in response to a User request, in a number of ways, 
including, for example: 

15 a) In a first configuration, processor 25 accesses web 

page data that is continuously transmitted in the satellite 
broadcast received from decoder 30, 

b) In a second configuration, processor 25 acquires 
2 0 web page data that is transmitted in the satellite broadcast 

received from decoder 30 in response to an information request to 
a service provider via telephone line, and 

c) In a third configuration, processor 25 both requests 

2 5 information and receives response informaiion on the same 

communication link e.g. on the telephone link to server 83. 

First configuration of Processor 25 

3 0 In the first configuration, web page data selected by a 

User via the displayed program guide is continuously transmitted 
within the transport datastream input to processor 25 from 
decoder 30. In this configuration, the composite program map 
information contains predetermined PID values for the requested 
3 5 web page. Consequently,, the requested web page data is retrieved 
from the input transport stream using the composite program map 
information without the need for controller 115 to communicate 
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with a service provider via modem 80. In this configuration, the 
web information available to a User is limited to the specific 
information that a service provider continuously transmits to 
processor 25 using dedicated transmission bandwidth. However, 
5 this configuration is simple and offers quick web page access 
(since the web data may be stored locally at the encoder by the 
service provider). This configuration also minimizes the service 
provider burden of data acquisition and eliminates the need for 
processor 25 to communicate web page request information to a 

1 0 service provider. 

The web page information, encoded in HTML™ and 
Java™, is packetized and formatted in an encoder by the service 
provider for incorporation into the MPEG transport datastream for 
transmission. Figure 3 shows a data format, according to the 

1 5 invention, for packetizing Internet data for transmission within an 
MPEG compatible datastream. A sequence of HTML™/Java™ web 
pages (705-720 of Figure 3) is formed by the encoder into non- 
compressed packets with ancillary information and HTML™/Java™ 
data (725). The ancillary information includes PID values, a packet 

20 count value, and individual web page size (e.g. number of bytes or 
image pixel size). The ancillary information may also include: a 
flag to indicate that a particular transport packet contains web 
page information; a start code; a web page identification code; an 
error correction code and a timing parameter suitable for 

25 synchronizing web page Internet information with an associated 
video or audio program. The web page flag may be used to 
facilitate identification and separation of the web page 
information from the MPEG compressed video data. Further, one 
or more elements of the web page ancillary data may be included 

3 0 within User definable elements of the MPEG transport syntax, such 
as within the transport header, or it may be included along with 
the web page information in the MPEG transport data payload. 

The response web page information, including a 
predetermined PID value, is incorporated in the MPEG compatible 

3 5 transport datastream input to processor 25 (Figure 1) by the 
service provider. The response channel predetermined PID value 
is also prestored in controller 115 internal memory and 
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incorporated in the composite program map information. As an 
alternative, the response data PID value and associated program 
map data may be encoded, for example, in a Channel Information 
Table (CIT) in a high definition television (HDTV) signal encoded 
5 according to the Digital Television Standard for HDTV 
Transmission of April 12 1995, prepared by the United States 
Advanced Television Systems Committee (ATSC). In such a case, 
one or more specific pre-determined program channels may be 
designated to convey web page response information. Further, the 

10 PID values of the program channels may be conveyed in a CIT in 
the composite program map information, for example. 

Controller 115 derives the predetermined PID value 
corresponding to the requested web page response information 
from the stored composite program map information and loads it 

15 into control registers within unit 45. Unit 45 matches the PIDs of 
incoming packets of web page response data in the transport 
datastream from decoder 30 with the PID value pre-loaded in the 
unit 45 control registers. The packets with PID values matching 
the pre-determined web response PID value are identified as web 

2 0 page response data and are provided by unit 45 to a dedicated 

buffer in decoder 55. The dedicated buffer in transport decoder 
55 holds response data to be decoded by processor 60. 

Processor 55 derives system information including 
timing, error and synchronization information from the 
25 datastream from unit 45 and provides it to controller 115. 
Controller 115 applies the system information in directing 
processor 55 to provide re-synchronized web page response data 
from the dedicated buffer in decoder 55 to HTML™/Java™ 
processor 60. Processor 60 decodes the HTML™ and Java™ encoded 

3 0 web response information and provides web page image 

representative pixel data for storage in memory within controller 
115. Although processor 60 is shown as a separate processor in 
Figure 1, it may also be implemented within the software of 
controller 115. Processor 60 comprises the processing functions of 
35 a special web browser, including JPEG decompression and Java 
decoding such as involved in the operation of Netscape 
Navigator™, for example. 
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Program content data e.g. a User selected television 
program channel, within the MPEG compatible transport 
datastream from decoder 30, is also decoded into pixel 
representative data by processor 25 in addition to the web page 
5 response data. For this purpose, controller 115 determines the PID 
value of the selected television channel program from the 
composite program map information and loads it into control 
registers within unit 45. Unit 45 matches the PIDs of incoming 
packets of selected television channel program data in the 

1 0 transport datastream from decoder 30 with the PID value pre- 
loaded in the unit 45 control registers. The packets with PID 
values matching the pre-determined selected television channel 
program PID value are identified and provided by unit 45 to a 
dedicated application buffer in decoder 55. 

15 As previously described for the web page response 

data, processor 55 derives system information including, timing, 
error and synchronization information from the datastream from 
unit 45 and provides it to controller 115. Controller 115 applies 
the system information in directing processor 55 to provide re- 

2 0 synchronized program channel content data from the application 
buffer in decoder 55 to MPEG decoder 65. The MPEG compatible 
program channel content data is decompressed by MPEG decoder 
65 to provide video pixel data and audio output data to display 
processor 70. The video pixel data from decoder 65 is stored in a 

2 5 pixel representative memory contained in display processor 70. 

Controller 115 retrieves the web page image pixel data 
from internal memory and formats it for storage as an overlay in 
the pixel representative memory contained in display processor 
70. As such a merged display combining the web page response 

3 0 data and program channel content is formed within the pixel 

memory of processor 70. The relative proportions and sizes of the 
web page image and channel content image within the resultant 
composite image, formed in the processor 70 pixel memory, may 
be varied by controller 115 in response to internal programmed 
3 5 instruction or external, e.g. User, command. The relative 
proportions may be varied so that either the web page image or 
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channel content image contributes between 0-100% of the 
resultant composite image. 

In order to adjust the proportion of the composite 
image contributed by the web page data, controller 115 scales the 
5 web page image pixel data by a conventional interpolation 
process. Alternatively, the data may be scaled by a separate video 
processing integrated circuit operating in conjunction with 
controller 115. The resulting scaled web page image is stored 
within the processor 70 pixel memory by controller 115. The 

1 0 stored web page image represents an overlay image with respect 
to the program channel content image. In order to adjust the 
location of the web page image data within the composite image, 
controller 115 determines the addresses corresponding to the 
desired memory locations from internal memory map data and 

1 5 stores the scaled web page image data at the desired memory 
locations. As previously explained, display processor 70 converts 
the formatted composite image data into conventional luminance 
and chrominance components. Further, processor 70 processes the 
luminance and chrominance components, together with timing 

2 0 data provided by controller 115, in a conventional manner to form 

an NTSC signal for display on NTSC compatible image reproduction 
device 75. 

Second configuration of Processor 25 

25 

In the second configuration, processor 25 of Figure 1 
acquires web page data that is transmitted in the satellite 
broadcast received from decoder 30 in response to an information 
request to a service provider via a telephone line. Upon a User 

3 0 requesting web page data, e.g. by highlighting web page icon 857 

in Figure 2, controller 115 (Figure 1) uses the request access data 
(telephone number, requested web page identifier code (e.g. URL) 
and conditional access data) to establish communication with the 
satellite broadcast service provider. 
3 5 Prior to establishing communication with the service 

provider, controller 115 determines from conditional access 
information whether access to the requested web page 
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information is authorized. Authorization may be determined 
directly from the program guide conditional access information or 
indirectly from a User entitlement device such as a smart card 
(not shown to simplify the drawing) within processor 25. If access 
5 is authorized, controller 115 establishes telephone communication 
with the satellite broadcast service provider by dialing a 
telephone number via modem 80 and transmitting request 
information e.g. requested web page identifier code (such as a 
URL) and user entitlement code. The service provider incorporates 
1 0 the requested web page information in the transport datastream 
transmitted to processor 25 via antenna 10, processor 20 and 
decoder 30. Controller 115 uses the response access data (PIDs of 
the web page data, response program channel number and 
transponder number) to identify and assemble the web page 

1 5 packets in the transport stream as described for the first 

configuration of processor 25. 

The PID values of the response web page information 
and corresponding program map information may be 
communicated between service provider and processor 25 in a 

2 0 variety of ways and in a variety of data formats. The PID values 

and program map information may be conveyed, for example, in 
accordance with proprietary or custom requirements of a 
particular system such as within MPEG user definable data 
elements or within non-MPEG data such as within the vertical 

2 5 blanking interval (overscan region) of a broadcast television 

signal. Further, the PID values allotted to the web information 
may also be transmitted to processor 25 in supplemental program 
guide information. As another alternative, the PID values to be 
used for response data may be determined by a service provider 

3 0 from information transmitted from processor 25. 
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Third configuration of Processor 25 

In a third configuration, processor 25 both requests 
5 information and receives response information on the same 
communication link e.g. on the telephone link to server 83 or 
connection service 87, via modem 80. In this configuration, 
controller 115 requests Internet web page information by 
highlighting icon 857 (Figure 2), for example. Whereupon 

10 controller 115 (Figure 1) uses request access data (telephone 
number and URL code and conditional access data) to establish 
Internet access and request web page data at the URL address via 
modem 80 and server 83. Controller 115 determines whether the 
requested Internet access is authorized from conditional access or 

1 5 smart card User entitlement information as described in 
connection with the second configuration of processor 25. If 
authorized, controller 115 establishes telephone communication 
with a service provider via server 83 by dialing a telephone 
number using modem 80 and transmitting the Internet URL 

2 0 address code and user entitlement code, for example, as 
previously described. Controller 115 uses response access data 
(including Transmission Control Protocol/Internet Protocol 
(TCP/IP) identification data) determined from the composite 
program map information to identify and assemble the web page 

2 5 TCP/IP packets containing the web page HTML and associated 

JAVA data (and other data e.g. JPEG, GIF, TIF type data) in the 
response datastream from server 83. 

The response web page TCP/IP packets are buffered 
within modem 80 and provided to HTML™ processor 60 under 
30 command of controller 115. Processor 60 decodes the HTML™ and 
Java™ encoded web response information and provides web page 
image representative pixel data for storage in memory within 
controller 115. Controller 115 retrieves the web page image pixel 
data from internal memory and formats it for storage as an 

3 5 overlay in the pixel representative memory contained in display 

processor 70 for reproduction by unit 75 as a merged display, as 
previously described. In this configuration, processor 25 supports 
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full Internet access via server 83 using the displayed program 
guide. For example, upon a User highlighting icon 810 followed by 
icon 830 (Figure 2) controller 115 (Figure 1) executes web page 
browser functions and displays either a custom web page browser 
5 or a standard browser display such as Netscape Navigator™ 
through which full Internet access is available. 

Alternatively, in the third configuration, processor 25 
may support a limited Internet service. In this case, access to the 
Internet network via server 83 is under the control of a service 

1 0 provider that allows only indirect Internet access. The service 
provider provides collated web page information for display 
compatible with the displayed composite program guide. The 
service provider stores a limited number of web pages locally 
within server 83 that are accessible by processor 25 using the 

1 5 composite program map information which provides an index to 
the available web pages and their corresponding predetermined 
PIDs. Alternatively, the service provider may alter the selection of 
web pages available from server 83 and periodically provide 
updated compatible supplemental program guide information to 

2 0 processor 25 via the satellite broadcast datastream. 

The supplemental program guide information enables 
processor 25 to form an updated displayed guide together with 
compatible program map and other access information enabling a 
User to access the updated web information. By storing the web 

2 5 page Internet information locally in server 83 the service 

provider retains control of the Internet content available to a User 
and is able to bill the User for the material provided. Also, the 
local storage of the web page information in server 83 provides a 
User with faster access to the information without the full delay 

3 0 associated with normal Internet access. Further, the burden on 

processor 25 of communicating information requests to external 
devices is minimized in that only a limited quantity of Internet 
information may be requested and processor 25 need only 
communicate with local servers such as server 83. It is to be noted 
3 5 that modem 80 may also be a wide bandwidth communication 
modem such as a cable modem. In which case, processor 25 may 
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decode both web page data and broadcast video program data for 
display from a cable program source via modem 80. 

Controller 115 employs the method shown in Figure 4 
to produce a displayed program guide by processing and 
5 formatting received program guide information that already 
includes User selection menu options. The process of Figure 4 does 
not require processor 25 to form User selection menu options and 
may be employed by processor 25 in its first configuration, for 
example. In step 205, following the start at step 200, processor 25 
1 0 receives a transport datastream from decoder 30 that incorporates 
User selectable menu options for display as part of the displayed 
program guide. The User selectable options support User initiation 
of communication functions such as Email, telephone, Internet 
access, fax, video-phone, channel tuning, program recording and 

1 5 home control functions. 

The data received in step 205 also includes additional 
linking data in the program guide information. The additional 
linking data comprises program map, conditional access and 
network information and associates access data with the User 

2 0 selectable menu options in the displayed program guide. The 

access data includes, identification codes, communication protocol 
codes, conditional access codes, Internet access codes e.g. URL 
codes for web page and Email access as well as telephone and fax 
numbers. The additional linking data enables processor 25 to 

2 5 assemble, decode and display the program content and program 

guide information in the transport stream from decoder 30. The 
access data enables processor 25 to communicate with external 
devices and includes different address representative codes 
corresponding to addresses of different information sources. In 

3 0 step 210, controller 115 uses predetermined linking data PID 

values stored in internal memory in directing processor 25 to 
identify and capture the linking and access data from the received 
program guide information. The captured linking data is 
assembled, formatted and stored by controller 115 in internal 
3 5 memory in step 215. Also, in step 210, additional linking data 
such as Internet or Email addresses or telephone numbers may be 
entered by a User via an entry device such as a remote control 
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unit and the additional data is incorporated in the received linking 
data by controller 115. 

The program guide information containing the User 
selectable options, is formatted for display by controller 115 in 
5 conjunction with display processor 70 within processor 25 in step 
220, as previously described in connection with Figure 1. In step 
225, display processor 70 converts the stored and formatted 
program guide data into conventional luminance and chrominance 
components. The luminance and chrominance components, 

10 together with timing data provided by controller 115, are 
processed by processor 70 for display on reproduction device 75. 
The process of Figure 4 terminates at step 230. 

Controller 115 (Figure 1) employs the method shown 
in Figure 5 to produce a program guide in a video decoder from 

1 5 information received from a plurality of sources. The formed 
guide supports User selectable communication functions e.g. 
Internet access, Email, fax etc. . In step 305, following the start at 
step 300, controller 115 acquires satellite program guide (SPG) 
information from the satellite broadcast transport stream received 

2 0 by processor 25 from decoder 30. In step 310, controller 115 
acquires DVD program guide (DPG) information from storage 
device 90 via interface 95. Controller 115 acquires, collates and 
formats the SPG and DPG by accessing and assembling respective 
data packets to produce SPG and DPG representative pixel data for 

2 5 storage as a composite program guide in the unit 70 pixel map, as 

previously described in connection with Figure 1. The SPG and DPG 
information includes linking and access data in the form of 
program map, conditional access and network information. In 
other configurations, processor 25 applies the principles detailed 

3 0 herein to form a composite program guide including program 

guide information derived from a source such as a terrestrial 
broadcast source, a cable broadcast source, a computer source, a 
radio transmission source and a source accessed via telephone 
lines. 

3 5 In step 315, controller 115 creates User selectable 

menu options for display (for User selection of Internet access, 
Email, fax etc.) in pixel data form for incorporation in the unit 70 
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pixel memory map. In step 315, controller 115 also creates User 
determinable menu options that enable a User to customize his 
program guide to include an icon that performs a specific User 
requested function, for example, a User may require an icon that 
5 accesses a specific Internet site or results in a display of all 
received messages. Controller 115 responds to commands entered 
via a data entry device e.g. a remote control unit or keyboard in 
creating the User determinable menu option in accordance with 
programmed instructions. 

10 Controller 115, in step 320, examines the SPG and DPG 

information for data identifier (e.g. PID) omissions and conflicts. In 
step 325, controller 115 re-numbers existing data identifiers and 
allocates new data identifiers as required to produce compatible 
program map information for both the collated program guide 

1 5 information and the associated program content. In step 330, 
controller 115 forms composite program map, conditional access 
and network information for the composite program guide in the 
manner described in connection with Figure 1. 

The composite program map is formed to enable 

2 0 processor 25 to perform the communication functions selectable 
via the composite program guide. For this purpose, the composite 
program map associates a communication function PID and menu 
option (e.g. web page, Email, fax icon) with the different address 
representative codes corresponding to the addresses of the 

2 5 different information sources. In step 330, controller 115 also 

incorporates User entered data into the composite program map, 
conditional access and network information. This data may include 
items such as an Email address, a telephone/fax number, an 
Internet web page link address, a credit card number etc. The 

3 0 User enters this data to processor 25 via a device such as a remote 

control or keyboard. Controller 115, in step 335, formats the SPG 
and DPG pixel data together with the menu option pixel data in the 
unit 70 pixel map created in step 315 to form a composite 
program guide for display. 
3 5 The composite program guide information containing 

the User selectable menu options is formatted for display in step 
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340, and output in step 345 as previously described in connection 
with Figure 1. The process of Figure 5 terminates at step 350. 

Controller 115 (Figure 1) employs the process of Figure 
6 to automatically acquire and collate program guide information 
5 from a plurality of sources to form a composite program guide for 
display. In step 405, following the start at step 400, controller 115 
acquires and stores satellite program guide (SPG) information 
from the satellite broadcast transport stream received by 
processor 25 from decoder 30. Controller 115, in step 415, 

1 0 automatically initiates communication with DVD storage device 90 
(Figure 1), via interface 95. The communication is initiated upon 
power-up of processor 25 in response to pre-stored hardware 
configuration information defining the peripheral devices that are 
attached to processor 25 and the associated communication 

1 5 protocols. This information may be contained within the received 
program guide information, or may be stored within processor 25 
at manufacture, or may be determined locally by processor 25 or 
may be determined through a combination of these methods. The 
local determination of hardware configuration by processor 25 

2 0 may be accomplished either by peripheral interrogation initiated 
by controller 115, or by User data entry of hardware configuration 
data. 

In alternative embodiments, communication may be 
automatically initiated upon conditions such as, a) User command 

2 5 via a program guide option selection, for example, b) peripheral 

interrogation initiated by controller 115 on a periodic or 
intermittent basis, or c) detection of a new or changed electrical 
connection of processor 25 to a peripheral device such as DVD 
device 90. 

3 0 Controller 115 initiates communication with DVD unit 

90 via interface 95 using communication protocol codes, 
identification codes, entitlement codes and conditional access 
codes retrieved from the access data within the received program 
guide information. In step 420, controller 115 directs processor 25 
3 5 to acquire and assemble. the DVD program guide (DPG) information 
derived from DVD storage device 90 via interface 95 in the 
manner previously described in connection with Figure 1. In step 
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425, controller 115 collates the SPG and DPG information by theme 
and topic by mapping the SPG and DPG information to 
corresponding theme and topic categories in a master set, also as 
described in connection with Figure 1. Further, in step 425, 
5 controller 115 collates the SPG and DPG information by source and 
allocates a different color attribute to programs and program icons 
from different sources. In addition, controller 115 creates menu 
options permitting a User to sort by source and color. 

Figure 7 shows a black and white representation of a 

1 0 color Program Guide display format, according to the invention, 
showing menu options created by controller 115 permitting a User 
to collate programs by source and color attribute. Source icons 
905-925 are associated with off-air broadcast, cable, radio, 
satellite and storage (e.g. DVD source 90 - Figure 1) respectively. 

1 5 Source icons 930-950 are associated with Email, telephone, 
videophone, fax and Internet function sources respectively. Upon 
a User highlighting source icon 905, for example, a program guide 
is displayed showing off-air broadcast programs and associated 
icons. Similarly, upon a User highlighting source icon 930, for 

2 0 example, a program guide is displayed showing Email icons via 
which a User may activate menus for initiating composition and 
sending of Email messages and reading and deleting of messages 
received. 

Icon 900 is a "rainbow" sort icon showing a spectrum 

2 5 of discrete color blocks represented by shades of gray in the black 

and white program guide depiction of Figure 7. The color choices 
of icon 900 may alternatively be arranged as a continuous color 
spectrum or selected range of colors in a single or a number of 
discrete color blocks. Upon a user highlighting a particular color 

3 0 within icon 900, programs from the source attributed with that 

particular color are displayed. For example, assuming in step 425 
controller 115 attributes the color purple to the DVD source device 
90, then upon a user highlighting the color purple within icon 900, 
the movies available from DVD device 90 become displayed as a 
3 5 program guide. Alternatively, the color collation scheme may be 
used to identify programs by other criteria than source. Color may 
be used as an attribute to identify programs by theme or topic, for 
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example, in which case a display of movies available for viewing 
from all sources may be identified by highlighting a red color 
within icon 900, for example. In addition, program guide data may 
be collated by attributes other than color. For example, programs 
5 from different sources may be attributed with different types of 
shading or different icon shapes and geometry s. 

Continuing with the process of Figure 6, in step 430, 
controller 115 forms a composite program guide for display from 
the collated SPG and DPG information in a manner similar to that 
10 described in connection with Figure 1. Controller 115 also, in step 
425, creates associated User selectable menu options for display 
including the User selectable program guide options for sorting by 
source and color. The created menu options are incorporated by 
controller 115 in step 430 in a composite program guide for 
15 display as exemplified in Figure 7. In step 435, controller 115 
formats the composite program guide information for display as 
previously described in connection with Figure 1. The process of 
Figure 6 terminates at step 440. 

Controller 115 (Figure 1) employs the process of Figure 
20 8 to acquire web page information requested by a video receiver 
User via a selection made from options on a displayed program 
guide. In step 505, following the start at step 500, controller 115 
retrieves access data in the form of a telephone number and 
Internet URL code, for example, from memory in response to a 

2 5 User selection of a web page made via a displayed program guide. 

The access data associated with the particular User selection is 
determined from a program guide database using program map 
information that links all data associated with a particular 
program or program guide function. 

3 0 In step 515, controller 115 directs processor 25 to 

establish a request communication link with server 83 by dialing 
the retrieved telephone number using modem 80. Also, in step 
515, processor 25 encodes and transmits additional access data 
such as the Internet URL code using the protocol required for 
3 5 communication on the request communication link. The required 
protocol is determined from the program map information. In step 
520, controller 115 directs processor 25 to receive and decode an 
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input signal received on a response communication link. Controller 
115 directs processor 25 in identifying and retrieving the 
response web page information from the input signal in steps 525 
and 530. Different methods of retrieving response data from the 
5 input signal are employed by processor 25 in steps 525 and 530. 
The selected method depends on whether or not the response 
communication link is the same link used for the web page data 
request. The methods used in identifying and retrieving the 
response data are similar to those previously described in 

1 0 connection with the three configurations of processor 25. 
Controller 115 applies the appropriate configuration method in 
identifying the response web page data in the input signal, in step 
525. For this purpose, controller 115 uses data identifiers 
determined from program map information that associates the 

15 identifiers with the User program guide selection. Controller 115, 
in step 535, formats the response web page information for 
display and the Figure 8 process ends at step 540. 

Controller 115 (Figure 1) employs the process of Figure 
9 for decoding both input Internet information and compressed 

2 0 video data to form a composite video output for display. Following 
the start at step 600, controller 115, in step 605, determines 
packet identifiers for User requested Internet data and 
compressed image data from program map information. In step 
607, controller 115 determines whether access to the compressed 

2 5 video data and the requested Internet data is authorized from 

conditional access or smart card User entitlement information as 
previously described in connection with the third configuration of 
processor 25. 

If access is authorized, controller 115, in step 610, 

3 0 identifies the web page TCP/IP packets containing the web page 

data in a response datastream from server 83. Similarly, if access 
is authorized, controller 115, in step 615, identifies the 
compressed video data packets containing a User selected video 
program in an input transport stream from decoder 30 to 
3 5 processor 25. Controller 115 identifies the web page and 
compressed video data packets in a similar manner to that 
described in connection with Figure 1. 
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In step 617, controller 115 directs processor 25 
(Figure 1) to, decrypt Internet or compressed video data if it is 
encrypted. Controller 115 in step 620, directs processor 25 in 
decoding the identified Internet web page data using HTML™ 
5 processor 60. Controller 115 in step 625, directs processor 25 in 
decompressing the identified compressed video data using MPEG 
decoder 65. The resultant decoded web page data and 
decompressed video data is merged, formatted and displayed on 
unit 75 using display processor 70 under the direction of 
10 controller 115 in step 630. The process of Figure 9 terminates at 
step 640. 

The architecture of Figure 1 is not exclusive. Other 
architectures may be derived in accordance with the principles of 
the invention to accomplish the same objectives. Further, the 

1 5 functions of the elements of processor 25 of Figure 1 and the 
process steps of Figures 4-6, 8 and 9 may be implemented in 
whole or in part within the programmed instructions of a 
microprocessor. In addition, the principles of the invention apply 
to any form of MPEG or non-MPEG compatible electronic program 

20 guide. Further, the principles of the invention apply to 
communication on any form of communication link including via 
cable, infra-red, radio, microwave, and via a computer network. In 
addition, it is to be noted that the formation of the composite 
program guide as described herein may be performed at a location 

25 remote from a video receiver and accessed by the receiver via a 
communication network. 
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CLAIMS 

1. A composite data format including MPEG compatible 
video data and Internet image information suitable for conveying 
5 packetized video program data and associated web image 
information, comprising: 

MPEG system data including 

(a) a first transport packet with a header containing a 
first data identifier (PID) for identifying said video program data 

1 0 in a payload of said first transport packet; 

(b) a second transport packet containing 

a second data identifier (PID) for identifying said 
Internet information, said Internet information being contained in 
a payload of said second transport packet; and 
1 5 ancillary data containing said second data 

identifier and supporting identification and decoding of said 
Internet information. 



2. A data format according to claim 1, wherein 

2 0 said ancillary data includes at least one of: (a) a web 

image data start code; (b) a packet count; (c) packet length; (d) 
packet linking data; (e) a web image data indication flag; (f) a 
timing parameter for synchronizing web image information with a 
video or audio program; (g) web image size and (h) error 

2 5 correction data. 

3. A data format according to claim 2, wherein 

at least one element of said ancillary data is contained 
in said header of said second transport packet; and 

3 0 at least one element of said ancillary data is contained 

in said payload of said second transport packet. 

4. A data format according to claim 1, wherein 

said second data identifier is contained in a header of 
3 5 said second transport packet. 
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5. A data format according to claim 1, wherein 

said ancillary data is contained in said payload of said 
second transport packet. 

5 

6. A data format according to claim 1, wherein 

said MPEG system data includes program map 
information for associating said Internet information and said 
video program. 

10 

7. A data format according to claim 6, wherein 

said program map information associates said Internet 
information, said first data identifier and said second data 
identifier. 

15 

8. A data format according to claim 1, wherein 

said video program data is MPEG compatible 
compressed video data and said Internet information is non-MPEG 
compatible data. 

20 

9. A data format according to claim 8, wherein 

said Internet information comprises non-compressed 

video data. 



2 5 10. A method for decoding a datastream containing 

packetized video program data and associated web image 
information, comprising the steps of: 

identifying said video program data in a payload of a 
first transport packet using a first data identifier (PID) contained 

3 0 in a header of said first transport packet; 

deriving a second data identifier (PID) from ancillary 
data supporting identification and decoding of Internet 
information in a second transport packet; 

identifying said Internet information in a payload of 
3 5 said second transport packet using said second data identifier; and 

assembling said Internet information into an output 
datastream using said ancillary data. 
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11. A method according to claim 10, wherein in said 
assembling step 

said Internet information is assembled into said output 
5 datastream using at least one of: (a) a web image data start code; 
(b) a packet count; (c) packet length; (d) packet linking data; (e) a 
web image data indication flag; (f) a timing parameter for 
synchronizing web image information with a video or audio 
program; and (g) error correction data. 

10 

12. A method according to claim 10, including the 

steps of 

decoding said assembled Internet information using a 
first method to provide a first decoded output; 
1 5 decoding said video program data using a second 

method to provide a second decoded output. 

13. A method according to claim 12, wherein 

said first method decodes non-MPEG compatible 
2 0 Internet information, and 

said second method decompresses MPEG compatible 
compressed video data. 

14. A method according to claim 10, wherein in said 

2 5 deriving step 

said second data identifier is derived from program 
map information associating said second data identifier with said 
Internet information. 

3 0 15. A method according to claim 10, including the step 

of 

deriving said first data identifier from program map 
information associating said first data identifier with said video 
program data. 

35 
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16. A method for decoding a datastream containing 
packetized video program data and associated web image 
information, comprising the steps of: 

identifying said video program data in a payload of a 
5 first transport packet using a first data identifier (PID) contained 
in a header of said first transport packet; 

deriving a second data identifier (PID) from ancillary 
data supporting identification and decoding of Internet 
information in a second transport packet; 
1 0 identifying said Internet information in a payload of 

said second transport packet using said second data identifier; and 

synchronizing said Internet information with said 
video program using said ancillary data. 



15 17. A method according to claim 16, further including 

the steps of 

identifying audio program data, and 
synchronizing said audio data with said Internet 
information. 

20 
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